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Amendment Dated January 25. 2005 - Response to Office Action of October 25, 2004 

Amendments To the Claims 
Kindly replace the claims as follows. 

1. (previously presented) A computer, comprising: 

a processor pipeline designed to alternately execute instructions coded for first and 
second different computer architectures or coded to implement first and second different 
processing conventions; 

a memory for storing instructions for execution by the processor pipeline, the 
memory being divided into pa ges for management by a virtual memory manager, a Single 
address space of the memory having first and second pages; 

a memory unit designed to fetch instructions from the memory for execution by the 
pipeline, and to fetch stored indicator elements associated wit* respective memory pages of 
the single address space from which the instructions are to be fetched, each indicator element 
desxgned to store an indication of which of two different computer architectures and/or 
execution conventions under which instruction data of the associated page are to be executed 
by the processor pipeline, the first architecture having a pre-defined, established deriniuon, 
the computer providing a faithful implementation of the first architecture; 

the memory unit and/or processor pipeline further designed to recognize an execution 
flow from the first page, whose associated indicator element indicates the ft* architecture or 
execution convention, to the second page, whose associated indicator element indicates the 
first architecture or execution convention, and in response to the recognizing, to adapt a 
processing mode of the processor pipeline or a storage content of the memory to effect 
execution of instructions in the architecture and/or under the convention indicated by the 
indicator element corresponding to the instruction's page. 

2. (original) The computer of claim 1: 

wherein the two architectures are two instruction set architectures; 
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and wherein the adapting includes controlling instruction execution hardware of the 
computer to interpret the instructions according to the two instruction set architectures 
according to the indicator elements. 

3. (original) The computer of claim 1. wherein the two conventions are first and 
second calling conventions, and further comprising: 

hardware and/or software designed to recognize when program execution has flowed 
or transferred from a region whose indicator element indicate, the first calling convention to 
a regton whose indicator element indicates the second calling convention, and in response to 
the recognition, to alter the data storage content of the computer to create a program context 
under the second calling convention that is logically equivalent to a pre-alteration program 
context under the first calling convention. 
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4. (previously presented) A method, comprising the steps of: 
executing instructions fetched from first and second regions of a memory of a 
computer, the instructions of the first and second regions being coded for execution by 
computers of first and second architectures or following first and second data storage 
conventions, respectively, the memory regions having associated first and second indicator 
elements, the indicator elements each having a value indicating the architecture or data 
storage convention under which instructions from the associated region are to be executed 
the first architecture having a pre-defined, established definition, the computer providing a 
9 faithful implementation of the first architecture; 

when execution of the instruction data flows or transfers from the first region to the 
seoond, adapting the computer for execution in the second architecture or convention. 

5. (original) The method of claim 4, wherein: 
the regions are pages managed by a virtual memory manager. 
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6- (original) The method of claim 5, wherein the indicator elements are stored in a 
table of indicator elements distinct from a primary address translation table used by the 
virtual memory manager, the indicator elements of the table associated with corresponding 

pages of the memory. 

7. (original) The method of claim 5, wherein the indicator elements are stored in a 
table, each indicator element associated with a corresponding physical page frame. 

8- (original) The method of claim 5, wherein the entries are entries of a translation 
look-aside buffer 



9. (original) The method of claim 4, wherein the regions are lines of an instruction 

cache. 



10. (original) The method of claim 4: 

wherein the two architectures are two instruction set architectures; 

and wherein the adapting step includes controlling instruction execution hardware of 
the computer to interpret the instructions according to the two instruction set architectures 
according to the indicator elements. 

11. (original) The method of claim 10, wherein: 

the regions are pages managed by a virtual memory manager. 

12. (previously presented) The method of claim 11, wherein the indicator elements 
are stored in a table whose entries are indexed by physical page frame number. 

13. (original) The method of claim U , wherein the entry is one entry of a translation 

look-aside buffer. 
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14. (original) The method of claim 10, wherein a mode of execution of the 
instructions is changed without software intervention when executton flows or transfers from 
the first region to the second. 



15. (original) The method of claim 10, wherein execution of the computer takes an 
exception when execution flows or transfers from the first region to the second. 

16. (original) The method of claim 15. wherein the mode of execution of the 
instructions is explicitly controlled by an exception handler. 

17. (original) The method of claim 10, wherein: 

one of the regions stores an off-the-shelf operating system binary coded in an 
instruction set non-native to the computer, the non-native instruction set providing access to a 
reduced subset of the resources of the computer. 



18. (original) The method of claim 10, wherein the two conventions are first and 
second data storage conventions, and further comprising the step of: 

recognizing when program execution has flowed or transferred from a region whose 
.ndacator element indicates the first data storage convention to a region whose indicator 
element indicates the second data storage convention, and in response to the recognition 
altermg the data storage content of the computer to create a program context under the ' 
second data storage convention that is , ogicalJy ^vzlent to a pre . aUeration program 
context under the first data storage convention. 

19. (original) The method of claim 18, wherein: 

the regions are pages managed by a virtual memory manager; 



Response to Office Action c luen , m JAA „ 

This paper dated January 25. 2005 114596-03-4000 S/N 09/385,394 

2727886.3 



PACE 12/64 * RCVD AT 1/25/2005 7:44:34 PM [Eastern Standard Time)* SVR:USPTO-EFXRM/2 " DNIS:872930S * CSID:2127288111 * DURATION (miTV-SS):23-32 



v FROM WILLKIE FARR 3 7 FAX DEPT 



(TUE) 1. 25' 05 1 9: 52/ST. 19: 47/NO. 4261629996 P 



Application Serial No. 09/385,394 
Attorney Docket No. 1 14596-03-4000 

Amendment Dated January 25, 2005 - Response to Office Action of October 25, 2004 

one of the two data storage conventions is a register-based calling convention, and the 
other data storage convention is a memory stack-based calling convention. 

20. (original) The method of claim 18, further comprising the steps of: 

classifying control-flow instructions of a computer instruction set into a plurality of 

classes; and 

during execution of a program on a computer, as part of the execution of instructions 
of the instruction set, updating a record of the class of the classified control-flow instruction 

most recently executed; 

the adjusting process being determined, at least in part, by the instruction class record. 

21. (previously presented) The method of claim 1 8, wherein: 
the instruction data coded for execution by a first of the two instruction set 
architectures observes a data storage convention associated with the first architecture and 
instructs data coded for execution by a second of the two instruction set architectures 
observes a second, different, data storage convention associated with the second architecture 
a smgle mdicator element indicating both the instruction set architecture and the data storage' 
convention; 

and further comprising the step of recognizing when program execution flows or 
transfers from a region using the first instruction set architecture to a region using the second 
instructs set architecture, and in response to the recognition, adjusting the data storage 
content of the computer from the first storage convention to the second. 

22. (previously presented) A method, comprising the steps of: 
executing instructions fetched from first and second regions of a memory of a 
computer, the instructions of the first and second regions being coded for execution by 
computers following first and second data storage conventions, the memory regions having 
assorted first and second indicator elements, the indicator elements each having a value 
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6 indicating the data storage convention under which instructions from the associated region 

7 are to be executed; 
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cognizing when program execution has flowed or transferred from a region whose 
mdicator dement indues the first data storage convention to a region whose indictor 
10 dement indzcates the second data storage convention, and in response to the recognition 
altering the data storage content of the computer to create a program context under the ' 
second data storage convention that is logically equivalent to a pre-alteration program 
13 context under the first data storage convention. 

23. (previously presented) The method of claim 22, further comprising the step of: 
overlaying the logical resources of the first and second instruction set architectures 
onto the physical resources of the computer according to a mapping that assigns 
corresponding resources of the two architectures to a common physical resource of a 
computer when the resources serve analogous functions in the calling conventions of the two 
architectures. 

24. (previously presented) The method of claim 22, wherein the adjusting step 

further comprises: 

altering a bit representation of a datum from a first representation in the first 
convention to a second representation in the second convention, the alteration of 
representation being chosen to preserve the meaning of the datum across the change in data 
storage convention. 



comprises: 



25. (original) The method of claim 22, wherein the adjusting step further 
copying a datum from a first location to a second location, the first location having a 

use under the first data storage convention analogous to the use of the second location under 

the second data storage convention. 
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26. (original) The method of claim 22, wherein the adjusting step further comprises: 
copying a datum from a third location to a fourth, the third location having a use 
under the first data storage convention analogous to the use of the third location under the 
first data storage convention and to the fourth location under the second data storage 
convention, a program for the copying being programmed to assume that exactly one of the 
first and third locations is no longer required by the execution of the program. 

27. (previously presented) The method of claim 22, wherein 
a rule for copying data from the first location to the second is determined by 
examining a descriptor associated with the instruction before the recognized execution flow 

or transfer. 



28. (original) The method of claim 22, wherein the two conventions are two calling 
conventions. 



29. (original) The method of claim 28, wherein: 

one of the two calling conventions is a register-based calling convention, and the 
other calling convention is a memory stack-based calling convention. 

30. (original) The method of claim 28, wherein: 

the regions are pages managed by a virtual memory manager. 

31. (previously presented) The method of claim 30, wherein the indicator elements 
are stored in a table whose entries are indexed by physical page frame number. 

32. (original) The method of claim 31, wherein the entry is one entry of a translation 

look-aside buffer. 
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33. (previously presented) The method of claim 28, further comprising the step of: 
taking a processor exception in response to the recognition, a handler for the 

exception programmed to copy a datum from a first location to a second location, the first 
location having a use under the first data storage convention analogous to the use of the 
second location under the second data storage convention. 

34. (previously presented) The method of claim 22, further comprising the step of 
classifying control-flow instructions of a computer instruction set into a plur ality of 

classes; and 

during execution of a program on a computer, as part of the execution of instructions 
of the .nstruction set, updating a record of the class of the classified control-flow instruction 

most recently executed; 

the adjusting process being determined, at least in part, by the mstruction class record. 

35. (original) The method of claim 34, wherein: 

one of the two data storage conventions is a register-based calling convention, and the 
other data storage convention is a memory stack-based calling convention. 

36. (original) The method of claim 34, wherein: 

in some of the control-flow instructions, the classification is statically determined by 

the opcode of the instructions; and 

in other of the control-flow instructions, the classification is dynamically determined 
based on a fuWempty status of a register. 



37. (previously presented) A computer processor, comprising: 

2 a processor pipehne configured to alternately execute instructions of computers of 

3 two different architectures or processing conventions; and 
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a memory unit designed to fetch .nstructions from a computer memory for execution 
by the pipeline, and to fetch stored indicator elements associated with respective memory 
regions of a single address space from which the instructions are to be fetched, each indicator 
dement designed to store an indtcation of the architecture or execution convention under 
which the instruction data of the associated region are to be executed by the processor 
pipeline, the first architecture having a pre-defined, established definition, the computer 
providing a faithful implementation of the first architecture; 

the memory unit and/or processor pipeline further designed to recognize an execution 
flow or transfer from a region whose indicator element indicates one architecture or 
13 execution convention to another. 

38. (original) The computer processor of claim 37, wherein the indtcator elements 
are stored in a table of indicator elements distinct from a primary address translation tab, e 
used by the virtual memory manager, the indicator elements of the table associated with 
corresponding pages of the memory. 



39. (previously presented) The computer processor of claim 37, further comprising: 
a translation look-aside buffer (TLB); and 

TLB control circuitry designed to load the indicator elements into the TLB from a 
table stored in memory, the entries of the table being indexed by associated with 
corresponding physical page frame number. 



40. (original) The computer processor of claim 37, wherein the two architectures an 
two instruction set architectures, and further comprising: 

processor pipeline control circuitry designed to control the processor pipeline to 
effect interpretation of the instructions under the two instruction set architectures alternately, 
according to the associated indicator elements. 
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41. (original) The computer processor of claim 40, further comprising: 
software programmed to manage a transition between the execution of a program 

executing in the first instruction set architecture, betng an instruction set architecture native 
to the computer processor, and execution of an off-the-shelf operating system coded in the 
second instruction set, being an instruction set non-native to the computer, providmg access 
to a reduced subset of the resources of the computer. 

42. (original) The computer processor of claim 40: 

each indicator element being further designed to store an indication of a calling 
convention under which the instruction data of the aviated regionarecode4forexecu.cn 
by the processor pipeline; 

and further comprising software programmed to alter the data storage content of a 
computer using the computer processor to create a program context under the second caning 
conventton that is logically equivalent to a pre-alteration program context under the first 
calling convention; 

the memory unit further designed to recognize when program execution has flowed or 
transferred from a region whose indicator element indicates the first calling convention to a 
regxon whose indicator element indicates the second calling convention, and in response to 
the recognition, to invoke the transition management software. 

43. (original) The computer processor of claim 42. wherein the memory unit is 
deigned to recognize a single indicator element to indicate both the instruction set 
architecture and calling convention of a region. 

44- (origmai) The computer processor of claim 42, wherein the memory unit and 
software are designed to effect a transition between instruction boundaries, between 
execution in a region coded in the first instruction set using the first calling convention to 
execute in a region coded in the second mstruction set using the second calling convention, 
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so that code at the source of the flow or transfer may effect the execution transition without 
being specially coded for code at the destination. 

45. (original) The computer processor of claim 42, wherein: 

one of the two calling conventions is a register-based calling convention, and the 
other caJling convention is a memory stack-based calling convention. 

46. (original) The computer processor of claim 42, wherein the logical resources for 
support of the first and second instruction set architectures are overlaid on the physical 
-sources of the computer processor according to a map p ing ^ assigns corresponding 
resources of the two architectures to a common physical resource when the resources serve 
analogous functions in the calling conventions of the two architectures. 

47. (previously presented) The computer processor of claim 42, wherein 

a rule for altering the data storage content from the first calling convention to the 
second is determined by examining a descriptor associated with the location of execution 
before the recognized execution flow or transfer. 

48. (original) The computer processor of claim 42, wherein control-flow instructions 
of the instruction set are classified into a plurality of classes; and 

the processor pipeline updates a record of the class of the classified control-flow 
instruction most recently executed; 

the storage alteration process being determined, at least in part, by the instruction 

class record. 

49. (original) The computer processor of claim 40, further comprising: 

a transition manager designed to effect a transition between the execution of code 
coded in instructions of a first instruction set architecture and code coded in instructions of a 
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second instruct set arcrutecture, the transition manager designed to alter a bit 
repre S entat,on of a datum from a first represents under thc first archjtecture tQ a ^ 
representation under the second arch.tecture, the aJteration of representation being chosen to 
preserve the meaning of the datum across the change in execution architecture. 

50. (original) The computer processor of claim 40, further comprising circuitry 
destgned to raise an exception when the computer recognizes that execution has flowed or 
transferred from a region whose indicator element indicates one architecture or execution 
convention to another. 



51. (previously presented) A method, comprising: 

storing instructions tn pages of a computer memory managed by a virtual memory 
manager, the instruction data of the pages being cooed for execution by, respectively 
computers of two Afferent architectures and/or under two different execution convention, 
5 m association with pages of the memory, storing corresponding mdicator element, 

Seating the architecture or convention in which the inactions of the page, are to be 

7 executed, the pages' indicator elements being stored in a table whose entries are mdexed by 

8 physical page frame number; 

executing instructions from the pages in a common processor, the processor designed 
responsive to the page indicator elements, to execute instructions in the architecture or under' 
1 1 the convention indicated by the indicator element corresponding to the instruction's page. 

52. (previously presented) The method of claim 51, wherein the pages' indicator 
elements cached in a translation look-aside buffer. 

53. (previously presented) The method of claim 51, wherein me two m 
two mstnuction set architectures, and further comprising the step of: 



7 
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controlling the inS truction execution hardware of the computer to interpret the 
mstructtons according to the two instruction set architectures accordtng to the indoor 

element. 



54. (previouslypnesented) The method ofclaim 51, where, the two conventions are 
first and second data storage conventions, and further comprising the step of: 

recognizing when program execution has flowed or transferred from a region whose 
mdicator e.cment indicates the first data storage convention to a region whose indicator 
element indtcates the second data storage convention, and in response to the recognition 
altering the data storage content of the computer to create a program context under the 
second data Storage convention that is logically equivalent to a pre-atteration program 
context under the first data storage convention. 

55. (previously presented) The method of claim 54, further comprising the steps of 

stonng action data in a third page, the instruction data of the third page being 
coded for execution by one of the two architectures, and observing a data storage convention 
associated with the other of the two architectures; 

storing indicator elements indicating the data storage convention observed by the 
instructions of the respective pages; and 

recognizing each transition of program execution from a page using the first data 
storage convention to a page using the second data storage convention, and in response to the 
recognition, adjusting the data storage content of the computer from the first storage 
convention to the second, and vice-versa. 

56. (previously presented) The method of claim 53, wherein: 
the instruction data coded for execution by a first of the two instruction set 
archuectures observes a data storage convention associated with the ft* architecture and 
instruction data coded for execution by a second of the two instruction set architectures 
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observes a second, Afferent, data storage convendon associated with the second architecture 
a angle mdicator e.ement inditing both the instruction set architecture and the data storage' 
convention of the associated page; 

and further comprising the step of recognizing when program execution flows or 
transfers from a page using the first instruction set architecture to a page using me second 
mstruct,on set architecture, and in response to the recognition, adjusting the data storage 
content of the computer from the first storage convention to the second. 

57. (piously presented) The method of claim 54, wherein the two conventions are 
a raster-based calling convention and a memory stack-based calling convention, and further 

comprising the step of: 

recognizing when program execution has flowed or transferred from a page using Ac 
tegmer-based calling convention to . page using to memory stack . bMed convenlion ^ 
response .0 the recognition, adjusting the cUua storage content of the computer from the te 

calling convention to the second. 

58. (original, T7,e m«hod of clam, 54, whetein the adjusting step further comprises- 
copy „g a datum from a third location to a fourth, the third location having a use 
under the fimdata storage convention analogous to the use of the third location under the 
first data storage convention ,„ d to the fourd, location under the second data storage 
convention, a program for the copying being program „, ^ ^ ^ ^ rf ^ 
first and third locates is no longer required by to execution of the program a bit 
representation of the datum copied ,0 to second IO cation differing from a bi, representation 
of to datum copied from to firs, ^atfon, to alteration of .presentation being chosen ,„ 
preserve to meaning „f to datum ^ me ^ jn ^ ^ ^ ^ 
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59. (previously presented) The method of claim 54, wherein 

a rule for copying data from the first location to the second is determined by 
examining a descriptor assocated with the instruction before the recognized execution flow 
or transfer. 

60. (original) The method of claim 54, further comprising: 

clarifying control-flow inactions of a computer instruction set into a plurality of 

classes; and 

during execution of a program on a computer, as part of the execution of instructions 
of the instruction set. updating a record of the class of the classified control-flow instruction 

most recently executed; 

the altering process being determined, at least in part, by the inaction class record. 

61. (cancelled) 

62. (cancelled) 



63. (currently amended) A microprocessor chip, comprising: 

2 an instruction unit, configured to fetch instructions from a memory managed by the 

3 virtual memory manager, and configured to execute instructions coded for first and second 
Afferent computer architectures or coded to implement first and second different data storage 

5 conventions; 

the microprocessor chip being designed (a) to retrieve indicator elements stored in 
association with respective pages of the memory, each indicator element indicating the 
architecture or convention in which the infraction, of the page are to be executed, and (b) to 
recognize when instruction execution has flowed or transferred from a page of the first 
architecture or convention to a page of the second, as indicted by the respective associated 
1 1 indicator elements, and (c) to alter a processing mode of the instruction unit or a storage 
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12 content of the memory to effect execution of instructions in accord with the indicator element 

13 associated with the page of the second architecture or convention; 

14 wherein the indicator elements are stored in a table distinct from a primary address 

15 translation table and from portions of the nrirrwv ,HH r .c S tranR i ari nn t , M , .„ n ^ „ 

16 teslatig n lookaside buffer) used by a virtual memory manager, the indicator elements of 

17 the table being stored in association with respective pages of the memory. 

64. (previously presented) The microprocessor chip of claim 63, wherein the 
indicator elements are stored in association with respective physical page frames. 

65. (previously presented) The microprocessor chip of claim 63, wherein the 
indicator elements are stored in association with respective virtual pages. 

66. (previously presented) The microprocessor chip of claim 63, wherein the 
indicator elements are stored in entries of a translation look-aside buffer. 

67. (previously presented) The microprocessor chip of claim 63, wherein the 
indicator elements are stored in an instruction cache. 

68. (previously presented) The microprocessor chip of claim 63, wherein a mode of 
execution of the instructions is changed without software intervention when execution flows 
or transfers from the first region to the second. 

69. (previously presented) The microprocessor chip of claim 63, the microprocessor 
chip being designed to raise an exception when execution flows or transfers from the first 

region to the second; 

and further comprising exception handler software programmed to handle the 
exception by explicitly controlling a mode of execution of the instructions. 
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70. (previously presented) The microprocessor chip of claim 63, wherein the 
architecture or convention indicator element, are stored in a table whose entries are indexed 
by physical page frame number, and cached in a translation look-aside buffer. 

71. (previously presented) The microprocessor chip of claim 63, wherein the two 
architectures are two instruction set architectures, and the microprocessor chip controls the 
instruction unit to interpret the mstructions according to the two instruction set architectures 
accordmg to the indicator element corresponding to the pages from which the instructions are 

fetched. 

72. (original) The microprocessor chip of claim 71, further comprising: 
software programmed to manage a transition between the execution of a program 

executing in the first instruction set architecture, being an instruction set architecture native 
to the computer processor, and execution of an of f-th e , s helf operating system coded in the 
second instruction set, being an instruction set non-native to the computer providing access to 
a reduced subset of the resources of the computer. 

73 (previously presented) The microprocessor chip of claim 71: 

each indicator element being further designed to store an indication of a data storage 

convention under which the instruction data of the associated page are coded for execution 

by the instruction unit; 

and further comprising software programmed to alter the data storage content of a 
computer using the microprocessor chip, to create a program context under the second data 
storage convention that is logically equivalent to a pre-alteration program context under the 

first data storage convention; 

the microprocessor chip further designed to recognize when program execution has 
flowed or transferred from a region whose indicator element indicates the first data storage 
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convention to a region whose indicator element indicates the second data storage convention, 
and in response to the recognition, to invoke the transition management software. 

74. (original) The microprocessor chip of claim 73, being further designed to: 
to retrieve instruction data from a third page, the instruction data of the third page 

being coded for execution by a first of the two architectures, and observing a data storage 

convention of the second of the two architectures; 

to retrieve indicator elements indicating the data storage convention observed by the 
instructions of the respective pages; and 

to recognize each transition of program execution from a page using the first data 
storage convention to a page using the second data storage convention, and in response to the 
cognition, to adjust the data storage content of the computer from the first data storage 
convention to the second data storage convention, and vice-versa. 

75. (original) The microprocessor chip of claim 73, further designed to recognize a 
single indicator element to indicate both the instruction set architecture and calling 
convention of a page. 

76. (previously presented) The microprocessor chip of clatm 71, further comprising 
hardware and/or software designed: 

(a) to retrieve calling convention indicator elements stored in association with 
respective pages of the memory, each calling convention indicator element indicating which 
of a register-based calling convention or a memory stack-based calling convention is 
observed by instructions of the page; 

(b) to recognize when instruction execution has flowed or transferred from a page of a 
memory-based convention to a page of the register-based calling convention, as indicated by 
the calling convention indicator elements associated with the respective pages, and 
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(c) in response to the recognition, to alter a storage content of the computer to create a 
program context under the register-based convention logically equivalent to a pre-altcration 
program context under the memory-based convention. 

77. (previously presented) The microprocessor chip of claim 63: 
wherein the two conventions are first and second data storage conventions; 
and further comprising software programmed to alter the data storage content of a 
computer using the microprocessor chip, to create a program context under the second data 
storage convention that ,s logically equivalent to a P re-alteration program context under the 
tirst data storage convention; 

the microprocessor chip being further designed to recognize when program execution 
has flowed or transferred from a region whose indicator element indicates the first data 
storage convention to a region whose indicator element indicates the second data storage 
convention, and in response to the recognition, to invoice the transition management 
software. 



78. (original) The microprocessor chip of claim 77, wherein the microprocessor chip 
and software are designed to effect a transition between instruction boundaries, between 
execution on a page coded in the first instruction set using the first calling convention to 
execution on a page coded in the second instruction set using the second calling convention, 
the software programmed to effect the execution transition without the code at the source of 
Che transition being specially coded to interface with code at the destination of the transition. 

79. (original) The microprocessor chip of claim 77, wherein the two conventions are 
two calling. conventions. 

80. (original) The microprocessor chip of claim 79, wherein: 
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one of the two calling conventions is a register-based calling convention, and the 
Other Calling convention is a memory stack-based calling convention. 

81. (original) The microprocessor chip of claim 79, wherein the physical resources of 
the microprocessor chip are associated to the logical resources of the first and second calling 
conventions according to a mapping that assigns corresponding logical resources to a 
common physical resource when the rescues serve analogous functions in the two calling 

conventions. 



82. (original) The microprocessor chip of claim 79, further comprising: 
software and/or hardware designed to effect a transition between the execution of 
code coded under the first calling convention and code coded under the second calling 
convention, by altering a bit representation of a datum from a first representation under the 
first calhng convention to a second representation under the second calling convention the 
alteration of representation being chosen to preserve the meaning of the datum across the 
change in calling convention. 

83. (original) The microprocessor chip of claim 79. further comprising: 

software and/or hardware designed to copy a datum from a first location to a second 

locauon, the first location having a use under the first calling convention analogous to the use 
of tiie second location under the second calling convention. 

84. (previously presented) The microprocessor chip of claim 79, further comprising- 
software and/or hardware designed to copy a datum from a third location to a fourth 

the aunl location having a use under the first data storage convention analogous to the use of 
the nurd location under the first data storage convention and to the fourth location under the 
second data storage convention, the software and/or hardware for the copying being 
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programmed to assume that exactly one of the first and third locations ,s no longer required 
by the execution of the program. 

85. (previously presented) The microprocessor chip of claim 63. further comprising 
hardware and/or software designed: 

(a) to retrieve calling convention indicator elements stored in association with 
respective pages of the memory, each calling convention indicator element indicating which 
of a register-based calling convention or a memory stack-based calling convention is 
observed by instructions of the page; 

(b) to recognize when instruction execution has flowed or transferred from a page 
ustng the reglS ter-based calling convention to a page using the memory stack-based 
convents, as indicated by the calling convention indicator elements associated with the 
respective pages, and 

(0 in response to the recognition, to alter a storage content of the computer to cate a 

program context under the memory-b^d convention lo ^ lly e qu3valent to a 
program context under the register-based convention. 

86. (previously presented) The microprocessor chip of clai m 63, wherein control- 
flow instructions of the microprocessor's instruction set are classified into a plurality of 

classes; and 

the fetch and execute unit updates a record of the class of the classified control-flow 
instruction most recently executed; 

the storage alteration process being determined, at least in part, by the instruction 

class record. 



87. (currently amended) A method, comprising the steps of: 
executing a control-transfer instruction in the hardw a „ „r . ^..^ under a fim 
execution mode «*t«* of the [[a]] computer, the instruction being architecturally defined to 
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4 transfer control directly to a destination instruction for execution in the hardware n f 

5 computer in a second execution mode context of the computer; 
before executing the destination instruction, altering the data storage content of the 

computer to establish a program context under the second execution mode eeme* that is 
logically equivalent to the context of the computer as interpreted under the first execution 
9 mgdeeeme*, the reconfiguring including at least one data movement operation not included 
10 in the architectural definition of the control-transfer instruction. 

88. (original) The method of claim 87, wherein the data movement includes at least 

one of: 

copying data from a general register to a memory stack; and 
copying data from a memory stack to a general register. 

89. (currently amended) The method of claim 87, wherein: 
the transition for the first execution mode ***** to the second mode seme* is 

recognized in a difference between two indicator elements associated with the memory pages 
containing the control-transfer instruction and the destination instruction, respectively, the 
pages being under the management of a virtual memory manager. 

90. (previously presented) The method of claim 89, wherein the indicator elements 
are stored in a table whose entries are indexed by physical page frame number. 

91. (original) The method of claim 89. wherein the indicator element, are stored in 
entries of a translation look-aside buffer. 

92. (currently amended) The method of claim 87, further comprising the step of: 
altering a bit representation of a datum from a first representation in the first mode 

eeate** to a second representation in the second mode eeate*. the alteration of 
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representation being chosen to preserve the meaning of the datum acres, the change in 

execution mode context . 

93. (previously presented) The method of claim 87, wherein 

a rule for copying data from the source memory or register to the destination register 

or memory is determined by examining a descriptor associated with the address of the 

control-transfer instruction. 



4 



7 
8 
9 



94. (previously presented) A method, comprising the steps of: 



executtng a section of computer object code twice, without modification of the code 
3 section between the two executions, the code section materializing a destination address into 
a regtster and being architecturally defined to directly transfer control indirectly through the 
5 renter to the destination address. th e two executions materializing two different destination 

o addresses; 

the two destination code sections at the two materialized destination addresses being 
coded m two distinct instruction sets and, respectively, obeying the default calling 
conventio "^to^rttotnin*^^^^^ 
10 the others. 

95. (original) The method of claim 94, wherein: 

the code at the first destination receives floating-point arguments and returns floating- 
pomt return values using a register-based calling convention; and 

the code at the second destination receives floating-point ming . memory _ 

based stack calling convention, and returns floating-point va,ues using a register indicated by 

a top-of-stack pointer. 
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1 96. (currency amended) A microprocessor chip, comprising: 

2 two instruction decoders designed to decode instructions of firsi and second 

3 instruction sets, respectively, and circuitry of a sing]e instruction pipe , jne ^ ^ ^ 

4 the mstructions decoded by either of the two instruction decoders; 

* circuitry aad^seft^ designed to detect when execution flows or transfers control 

6 from code coded in one instruction set to code coded in the other, program code in the first 

7 and second instruction sets using first and second different data storage conventions, 

5 respectively; and 



10 
11 



arcuitry and/or software designed to respond to the detection by altering the data 
storage content of the computer to create a program context under the second data storage 
convention that is logical* equivalent to a pre-alteration program context under the first data 

1 2 storage con venti on . 

97. (previously presented) The computer processor of claim 96, wherein the memory 
untt and software are designed to effect a transition between instruction boundaries, between 
execute m a region coded in the first ins^ction set using the first data storage convention 
to execution in a region coded in the second instruction set using the second data storage 
convention, so that code at the source of the flow or transfer may effect the execution 
transttion without being specially coded for code at the destination. 

98. (previously presented) The microprocessor chip of claim 96, wherein the two 
data storage conventions are first and second calling conventions. 

99. (previously presented) The computer processor of claim 98, wherein- 
one of the two camng conventions is a register-based calling convention, and the 

other calling convention is a memory stack-based calling convention. 
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100. (previously presented) The microprocessor chip of claim 98, further 
comprising: 

software and/or hardware designed to copy a datum from a first location to a second 
location, the first location having a use under the first calling conventions analogous to the 
use of the second location under the second calling conventions. 

101. (previously presented) The microprocessor chip of claim 100, further 

comprising: 

software and/or hardware designed to copy a datum from a third location to a fourth, 
the third location having a use under the first data storage convention analogous to the use of 
the third location under the first data storage convention and to the fourth location under the 
second data storage convention, the software and/or hardware for the copying being 
programmed to assume that exactly one of the first and third locations is no longer required 
by the execution of the program. 

102. (previously presented) The computer processor of claim 98, wherein 

a rule for altering the data storage content from the first calling convention to the 
second calling convention is determined based on an instruction at the location of execution 
at the source of the recognized execution flow or transfer. 

103. (previously presented) The computer processor of claim 98, wherein 

a rule for altering the data storage content from the Brst calling convention to the 
second calling convention is determined by examining a descriptor associated with the 
instruction before the recognized execution flow or transfer. 



104. (previously presented) A method, comprising the steps of: 

2 executing instructions fetched from first, second and third regions of a single address 

3 space of the memory of a computer, the instructions of the first and second regions being 

S^S^k 2005 26 H4596-03-4000 S/N 09/385,394 

2727886.3 



PAGE 33/64 * RCVD AT 1/25/2005 7:44:34 PM (Eastern Standard Time] • 8VR:USPTO-EFXRF-1/2 * DNIS:8729306 ■ C8ID:21 2728811 1 • DURATION (mm-ss>:23-32 



FROM WILLXIE FARR 3 7 FAX DEPT 



(TUE) 1. 25' 05 1 9 : 59/ST. 1 9 : 47/NO. 4261 629996 P 



Application Serial No. 09/385,394 
Attorney Docket No. 1 14596-03-4000 

Amendment Dated January 25, 2005 - Response to Of fice Action of October 25. 2004 



re structure 



coded for execution by computers of first and second architectures, the instructions of the 
second and thtrd regl ons following first and second data storage conventions, respectively 
the memory regions having associated modifiable indicator elements, a hardware 

7 for storing the indicator elements enforcing a requirement that the memory regions be 

8 necessarily disjoint, the modifiable indicator elements each having , va.ue Seating the 

9 architecture and data storage convention under which instructions from the assoctated region 

10 are to be executed; 

1 1 when execution of the instruction data fl„„ s or erasers between the fim , seroI ,d md 

12 thud regions, adapting fa computer for execution in fa md/or co „ ^ rf 

13 the region transferred to. 

105. (previously presented) The method of claim 104, wherein: 
me regions are pages managed by a virtual memory manager. 

106. (previously presented) The method of claim 105, wherein the modifiable 
mdtcator elements are sto red in a table, each modifiable indicator element associated with a 
corresponding physical page frame. 

107. (previously presented) The method of claim !05, wherein the entries are entries 
of a translation look-aside buffer. 

108. (previously presented) The method of claim 104: 
wherein the two architectures are two instruction set architectures; 

and wherein the adapting step includes controlling instruction execution hardware of 
the computer to mterpret the instructions according to the two instruction set architectures 
according to the modifiable indicator elements. 
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109. (previously presented) The method of claim 108, wherein: 

one of the regions stores an off-the-shelf operating system binary coded in an 
instruction set non-native to the computer, the non-native instruction set providing access to a 
reduced subset of the resources of the computer. 

1 10. (previously presented) The method of claim 108, wherein the two conventions 
are first and second data storage conventions, and further comprising the step of: 

recognizing when program execution has flowed or transferred from a region whose 
modifiable indicator element indicates the first data storage convention to a region whose 
modifiable indicator element indicates the second data storage convention, and in response to 
the recognition, altering the data storage content of the computer to create a program context 
under the second data storage convention that is logically equivalent to a pre-alteration 
program context under the first data storage convention. 

111. (previously presented) The method of claim 104, wherein the two conventions 
are first and second data storage conventions, and further comprising the step of: 

recognizing when program execution has flowed or transferred from a region whose 
indicator element indicates the first data storage convention to a region whose indictor 
element indicates the second data storage convention, and in response to the recognition, 
altering the data storage content of the computer to create a program context under the 
second data storage convention that is logically equivalent to a pre-alteration program 
context under the first data storage convention. 

112. (previously presented) The method of claim 111, wherein: 
one of the two data storage conventions is a register-based calling convention, and the 
other data storage convention is a memory stack-based calling convention. 
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1 1 13. (previously presented) A computer processor, comprising: 

2 a processor pipeline configured to alternately execute mstructions of computers of 

3 two different architectures; and 

4 a memory unit designed to fetch instructions from a computer memory for execution 

5 by the pipeline, and to fetch stored indicator elements associated with respective necessarily- 

6 dtsjomt memory regions of a single address space from which the instructions are to be 

7 fetched, each indicator element designed to store an indication of the architecture under 

8 which the instruction data of the associated region are to be executed by the processor 
pipeline, and to store a separate indicator element designed to indicate a data storage 
convention observed by instructions of the associated region; 

the memory unit and/or processor pipeline further designed to recognize an execution 
flow or transfer from a region whose indicator element indicates one instruction set 

13 architecture to another; and 

14 hardware and/or software designed to recognize when program execution has flowed 
or transferred from a region whose indicator element indicates the first data storage 
convention to a region whose indicator element indicates the second data storage convention 
and .n response to the recognition, to alter the data storage content of the computer to create a 
program context under the second data storage convention that is Jogically equivalent to a 
pre-alteration program context under the first data storage convention. 



10 

11 

12 



15 
16 
17 
18 
19 



114. (previously presented) The computer processor of claim 113, wherein the two 
archttectures are two instruction set architectures, and further comprising: 

processor pipeline control circuitry designed to control the processor pipeline to effect 
.interpretation of the instructions under the two instruction 5 et architectures alternately, according 



to the associated indicator elements. 
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115. (previously presented) The computer processor of claim 114, further comprising: 
software programmed to manage a transition between the execution of a program 

executing in the first instruction set architecture, being an instruction set architecture native to 
the computer processor, and execution of an off-the-shelf operating system coded in the second 
instruction set, being an instruction set non-native to the computer, providing access to a reduced 
subset of the resources of the computer. 

116. (previously presented) The computer processor of claim 1 14: 

the data storage convention indicator elements being designed to store an indication of a 
calhng convention under which the instruction data of the associated reg ion are coded for 
execution by the processor pipeline; 

and further comprising software programmed to alter the data storage content of a 
computer using the computer processor to create a program context under the second calling 
convention that is logically equivalent to a pre-ajteration program context under the first calling 



convention; 



the memory unit further designed to recognize when program execution has flowed or 
transferred from a region whose indicator element indicates the first calling convention to a 
reg,on whose indicator element indicates the second calling convention, and in response to the 
recognition, to invoke the transition management software. 



117. (cancelled) 

118. (cancelled) 



119. (previously presented) The computer processor of claim 120, wherein the memory 
unit and software are designed to effect a transition between instruction boundaries, between 
execution in a region coded in the first instruction set using the first calling convention to 
execution in a region coded in the second instruction set using the second calling convention, so 
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that code at the source of the flow or transfer may effect the execution transition without being 
specially coded for code at the destination. 

120. (previously presented) The computer processor of claim 1 16, wherein the two data 
storage conventions are two calling conventions. 

121. (previously presented) The computer processor of claim 1 20, wherein: 

one of the two calling conventions is a register-based calling convention, and the other 
calling convention is a memory stack-based calling convention. 

122. (previously presented) The computer processor of claim 120, wherein the logical 
resources for support of the first and second instruction set architectures are overlaid on the 
physical resources of the computer processor according to a mapping that assigns corresponding 
resources of the two architectures to a common physical resource when the resources serve 
analogous functions in the calling conventions of the two architectures. 



123. (previously presented) The computer processor of claim 120, further comprising: 
a transition manager designed to effect a transition between execution under the first 

calling convention to execution under the second calling convention, the transition manager 
designed to alter a bit representation of a datum from a first representation to a second 
representation, the alteration of representation being chosen to preserve the meaning of the 
datum across the change in calling convention. 

124. (previously presented) The computer processor of claim 120, further comprising: 
software and/or hardware designed to copy a datum from a first location to a second 

location, the first location having a use under the first calling convention analogous to the use of 
the second location under the second calling convention. 
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125. (previously presented) The computer processor of claim 124, further comprising: 
software and/or hardware designed to copy a datum from a third location to a fourth, the 

third location having a use under the first calling convention analogous to the use of the third 
location under the first calling convention and to the fourth location under the second calling 
convention, the software and/or hardware for the copying being programmed to assume that 
exactly one of the first and third locations is no longer required by the execution of the program. 

126. (previously presented) The computer processor of claim 120, wherein 

a rule for altering the data storage content from the first calling convention to the second 
is determined by examining a descriptor associated with the instruction before me recognized 
execution flow or transfer. 

127. (previously presented) The computer processor of claim 120, wherein control-flow 
instructions of the instruction set are classified into a plurality of classes; and 

the processor pipeline updates a record of the class of the classified control-flow 
instruction most recently executed; 

the storage alteration process being determined, at least in part, by the instruction class 

record. 

128. (previously presented) The computer processor of claim 1 13, wherein: 
the regions are pages managed by a virtual memory manager. 

129. (previously presented) The computer processor of claim 1 13, wherein the indicator 
elements are stored in virtual address translation table entries. 

130. (previously presented) The computer processor of claim 113, wherein the indicator 
elements are stored in a table of indicator elements distinct from a primary address translation 
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table used by the virtual memory manager, the indicator elements of the table associated with 
corresponding pages of the memory. 

131. (previously presented) The computer processor of claim 1 13, wherein the indicator 
elements are stored in respective entries of a table whose entries are indexed by physical page 
frame number. 

132. (previously presented) The computer processor of claim 1 13, wherein: 

the indicator elements are stored in storage that is architecturally addressable when the 
processor pipeline is executing in one of the computer architectures or processing conventions, 
and architecturally unaddressable when the processor pipeline is executing in the other 
architecture or convention. 

133. (previously presented) The computer processor of claim 1 13, further comprising 
circuitry designed to raise an exception when execution flows or transfers from a region whose 
indicator element indicates one architecture or execution convention to another. 

134. (new) The method of claim 87, wherein the first and second execution modes are 
first and second instruction set architectures. 

135. (new) The method of claim 87, wherein the first and second execution modes are 
first and second calling conventions. 
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